package cn.cvs.dao;

import cn.cvs.pojo.SysUser;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

public interface SysUserMapper {
    int count();

    List<SysUser> list();

    public List<SysUser> getUsersByRealName(String realName);

    /**
     * 查询用户列表
     * @param sysUser
     * @return
     */
    public List<SysUser> getUserListByPojo (SysUser sysUser);

    /**
     * 查询用户列表
     * @param userMap
     * @return
     */
    public List<SysUser> getUserListByMap(Map<String, Object> userMap);

    public List<SysUser> getUserListByParams (@Param("realName")String realName,@Param("roleId") int roleId);

    /**
     * 查询用户列，包括角色名称
     * @param sysUser
     * @return
     */
    public List<SysUser> getUserListWithRoleName(SysUser sysUser);

    /**
     * 根据角色ID查询用户，包含系统角色实例
     * @param roleId
     * @return
     */
    public List<SysUser> getUserListByRoleId(@Param("roleId") Integer roleId);


    /**
     * 根据用户ID查询用户及相关地址
     * @param userId
     * @return
     */
    public List<SysUser> getUserAndAddressesByUserId(@Param("userId") Integer userId);

    /**
     * 添加用户
     * @param sysUser
     * @return int 影响行数
     */
    public int add(SysUser sysUser);

    /**
     * 修改用户
     * @param sysUser
     * @return int 影响行数
     */
    public int modify(SysUser sysUser);

    /**
     * 修改个人密码
     * @param id
     * @param pwd
     * @return
     */
    public int updatePwd(@Param("id") Integer id, @Param("password") String pwd);

    /**
     * 删除用户
     * @param id 要删除用户的id
     * @return
     */
    public int deleteUserById(@Param("id") Integer id);



    /**
     * 第三章示例1
     */
    List<SysUser> selectList(@Param("realName") String realName,@Param("roleId") Integer roleId);

    /**
     * 第三章示例5
     */
    List<SysUser> selectListByChoose(SysUser sysUser);

    /**
     * 第三章示例6
     */
    List<SysUser> getUserByRoleIdArray(Integer [] roleId);


    /**
     * 第三章示例7
     */
    List<SysUser> getUserByRoleIdList(List<Integer> roleList);

    /**
     * 第三章示例8
     */
    List<SysUser> getUserByRoleIdMap(Map<String,Object> roleMap);

    /**
     * 第三章示例9
     * @return
     */
    int update(SysUser sysUser);

    /**
     * 第三章示例13
     *
     */
    List<SysUser> selectPageList(@Param("realName") String realName,
                                 @Param("roleId") Integer roleId,@Param("pageBegin") Integer pageBegin,
                                 @Param("pageSize") Integer pageSize);
}